<%--
  Created by IntelliJ IDEA.
  User: lingshao
  Date: 2020/9/16
  Time: 9:41
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>学生信息表</title>
    <script type="text/html" id="barDemo" class="layui-form" >
        <a href="javascript:;" style="font-size: 20px;font-family: 微软雅黑;" class="layui-btn layui-btn-sm layui-btn-radius layui-btn-warm layui-icon layui-icon-edit" lay-event="edit" >编辑</a>
        <a href="javascript:;" style="font-size: 20px;font-family: 微软雅黑;"  class="layui-btn layui-btn-sm layui-btn-radius layui-btn-danger layui-icon layui-icon-delete"  lay-event="delete" >删除</a>
        <a href="javascript:;" style="font-size: 20px;font-family: 微软雅黑;"  class="layui-btn layui-btn-sm layui-btn-radius layui-btn-danger  layui-btn-normal"  lay-event="reSetPwd" >重置密码</a>
    </script>

    <%--    引入layer--%>
    <script src="../jQuery/jquery-1.11.2.js"></script>
    <link rel="stylesheet" href="../layui/layui/css/layui.css" media="all">
    <script src="../layer/layer/layer.js"></script>

    <script src="../layui/layui/layui.js"></script>
    <style type="text/css">
        .layui-table-cell{
            height:50px;
            line-height: 50px;
        }
        *{
            font-size: 20px;
            font-family: 微软雅黑;
        }
    </style>
    <script type="text/javascript">
        $(function () {
            //查询所有班级
            $.ajax({
               async:false,
               url:"../ClassServlet?method=findClass",
                type:'GET',
                data:"",
                success:function (data) {
                    data=$.parseJSON(data);
                    var leng=data.json1;
                    var str="<option value=''>"+"--请选择班级名称--"+"</option>";
                    $.each(leng,function (index,item) {
                        str+="<option value="+item.className+">"+item.className+"</option>";
                    });
                    $("#className").append(str);
                    $("#classId").append(str);
                }
            });
        });
    </script>

</head>
<body>

<blockquote class="layui-elem-quote news_search">
    <%--头部工具栏--%>
    <div class="demoTable" id="demoTableId" hidden="true">
        <div class="layui-inline">
            <input style="width: 180px;height: 40px;" class="layui-input" placeholder="请输入学员姓名" name="stuName" id="stuName" autocomplete="off">
        </div>
        <div class="layui-inline">
            <select name="classId" id="className" >
<%--                <option value="">--请选择班级编号--</option>--%>
<%--                <option value="1">t281</option>--%>
<%--                <option value="2">t282</option>--%>
<%--                <option value="3">t283</option>--%>
<%--                <option value="4">t285</option>--%>
<%--                <option value="5">t286</option>--%>
<%--                <option value="6">t287</option>--%>
            </select>
        </div>
        <div class="layui-inline">
<%--            <input style="width: 180px;height: 30px; border-radius: 10px" class="layui-input" placeholder="请输入学员状态" name="stuItb" id="stuItb" autocomplete="off">--%>
            <select name="stuItb" >
                <option value="">--是否在籍--</option>
                <option value="在籍">在籍</option>
                <option value="不在籍">不在籍</option>
            </select>
        </div>
        <div class="layui-inline">
            <button  style="font-size: 15px;font-family: 微软雅黑;"	class="layui-btn layui-btn-radius layui-btn-normal  layui-icon layui-icon-search" lay-submit lay-filter="search">搜索</button>
        </div>
        <div style="float: right;margin-right: 50px;" class=" layui-inline">
            <a href="javascript:;" style="font-size: 20px;font-family: 微软雅黑;" class="layui-btn layui-btn-radius layui-icon layui-icon-add-circle"  lay-event="add">新建学员</a>
            <a href="javascript:;" style="font-size: 20px;font-family: 微软雅黑;" class="layui-btn layui-btn-radius layui-btn-danger layui-icon layui-icon-delete" lay-event="allDelete">批量删除</a>
        </div>
        </form>
    </div>

    <%--展示表格--%>
    <table id="demo" lay-filter="test"></table>
</blockquote>


<%--添加和修改弹出对话框--%>
<div style="display: none;" id="MaxDiv">
    <div style="margin-top: 40px;margin-left: 20px;">
        <form class="layui-form" id="mainForm" method="post" lay-filter="myForm">
            <div class="layui-form-item" >
                <label class="layui-form-label">学员编号</label>
                <div class="layui-input-inline">
                    <input type="text" name="stuId" style="width: 300px;"  id="stopText"  placeholder="请输入学员编号" autocomplete="off" class="layui-input" />
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">学员姓名</label>
                <div class="layui-input-inline">
                    <input type="text" name="stuName" style="width: 300px;"   lay-verify="required" placeholder="请输入学员姓名" autocomplete="off" class="layui-input" />
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">学生性别</label>
                <div class="layui-input-inline">
                    <input type="radio" name="stuSex" value="男" title="男">
                    <input type="radio" name="stuSex" value="女" title="女" >
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">班级名称</label>
                <div class="layui-input-inline" style="width: 300px">
                    <select  name="className" id="classId" >
<%--                        <option value="1">t281</option>--%>
<%--                        <option value="2">t282</option>--%>
<%--                        <option value="3">t283</option>--%>
<%--                        <option value="4">t285</option>--%>
<%--                        <option value="5">t286</option>--%>
<%--                        <option value="6">t287</option>--%>
                    </select>
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">身份证号</label>
                <div class="layui-input-inline">
                    <input type="text" name="selfId" style="width: 300px;"   lay-verify="required" placeholder="请输入学员身份证号码" autocomplete="off" class="layui-input" />
                </div>
            </div>
            <div class="layui-form-item" hidden="true">
                <label class="layui-form-label">密码</label>
                <div class="layui-input-inline">
                    <input type="text" name="stuPwd" style="width: 300px;" value="888888"   lay-verify="required" placeholder="请输入学员身份证号码" autocomplete="off" class="layui-input" />
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">学员电话</label>
                <div class="layui-input-inline">
                    <input type="text" name="stuPhone" style="width: 300px;"   lay-verify="required" placeholder="请输入学员电话" autocomplete="off" class="layui-input" />
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">是否在籍</label>
                <div class="layui-input-block" style="max-width:300px;">
                    <select name="stuItb" id="stopstuId" >
                        <option value="在籍">在籍</option>
                        <option value="不在籍">不在籍</option>
                    </select>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block">
                    <button class="layui-btn   " style="margin-left: 40px"  id="okk"  lay-submit lay-filter="okkFilter" >确认</button>
                    <button type="reset" class="layui-btn layui-btn-warm">重置</button>

                </div>
            </div>
        </form>
    </div>
</div>



<script type="text/javascript">
    layui.use(['table','layer','form'], function(){
        var table = layui.table;
        var layer=layui.layer;
        var form=layui.form;
        //定义一个编号，便于后期关闭div对话框
        var closeDiv;
        //，渲染表格
        table.render({
            elem: '#demo'
            ,cellMinWidth: 200
            ,height:665
            ,toolbar:"#demoTableId"
            ,method:'post'
            ,url: '../StudentServlet?method=findAll' //数据接口
            , limits: [5,10,15,20]  //一页选择显示3,5或10条数据
            , limit: 5  //一页显示10条数据
            // , parseData: function (res) { //将原始数据解析成 table 组件所规定的数据，res为从url中get到的数据
            //     var result;
            //     if (this.page.curr) {
            //         result = res.data.slice(this.limit * (this.page.curr - 1), this.limit * this.page.curr);
            //     }
            //     else {
            //         result = res.data.slice(0, this.limit);
            //     }
            //     return {
            //         "code": res.code, //解析接口状态
            //         "msg": res.msg, //解析提示文本
            //         "count": res.count, //解析数据长度
            //         "data": result //解析数据列表
            //     };
            // },
            // request:{ //改变请求中参数的名称
            //         pageName: 'page',//向后台传递的页码变量名称为page 不设置默认也是page
            //         limitName: 'rows' //向后台传递的每页行数名称为rows 不设置默认为limit
            //     }
            ,cols: [[ //表头
                {type:"checkbox",fixed: "left"}
                ,{field: 'stuId', title: '学员编号'}
                ,{field: 'stuName', title: '学员姓名'}
                ,{field: 'stuSex', title: '学员性别'}
                ,{field: 'className', title: '班级名称'/*,templet:function (d) {
                    if (d.classId==5){
                        return '<span style="color: #D03948;">t286</span>'
                    }else if (d.classId==1){
                        return '<span style="color: #18A4D0;">t281</span>'
                    }else if (d.classId==2){
                        return '<span style="color: #5CD03F;">t282</span>';
                    }else if (d.classId==3){
                        return '<span style="color: chartreuse;">t283</span>';
                    }else if (d.classId==4){
                        return '<span style="color: violet;">t285</span>';
                    }else if (d.classId==6){
                        return '<span style="color: #ff8080;">t287</span>';
                    }
                    }}*/}
                ,{field: 'selfId', title: '学员身份证号'}
                ,{field: 'stuPhone', title: '学员电话'}
                ,{field: 'stuItb', title: '学员是否在籍'}
                ,{fixed: 'right', title:'操作', toolbar: '#barDemo',align:'center',width:350,height:150}
            ]]
            ,page:true
        });



        //为删除和编辑添加事件
        /*
        * 删除：首先捕捉在功具条点击事件(添加对应的内置监听事件)，在函数中接收事件源，事件源.event获得的值即为
        * 点击标签的lay-event属性的值，取出值进行判断后，询问用户是否确认删除，确认后，通过ajax发送数据，接收
        * 响应后弹出提示并关闭询问框，最后刷新表格
        * */
        table.on("tool(test)",function(e){
            //判断点击的是删除事件
            //取得点击行的数据
            var data=e.data;
            if (e.event=="delete"){
                layer.confirm("确认要删除吗？",function(index){
                    //形式上删除这一行
                    e.del();
                    $.ajax({
                        type:"post",
                        url:"../StudentServlet?method=delete",//该路径仅供测试
                        data:"stuId="+data.stuId,
                        dataType:"text",
                        success:function(data){
                            if (data=="ok"){
                                layer.msg("删除成功",{icon:1,time:2000});
                                table.reload('demo');
                                //添加成功，返回了一行数据id,servlet接收后删除，删除成功后返回ok
                            }else{
                                layer.msg("删除失败",{icon:2,time:2000});
                            }
                        }
                    });
                    //点击后关闭对话框
                    layer.close(index);
                    //刷新表格
                    //table.reload("demo");
                });
            }else if (e.event=="edit"){//判断点击的为编辑
                //让主键不能修改
                $("#stopText").attr("readonly","readonly");
                //让密码不能修改
                $("#stopPwd").attr("readonly","readonly");
                //将确认按钮改为修改
                $("#okk").text("修改");
                //打开对话框
                closeDiv=layer.open({
                    type:1,
                    title:"修改内容",
                    offset: 'auto',
                    area:["500px","600px"],
                    content:$("#MaxDiv").html()
                });
                //将数据添加到表单当中
                form.val("myForm",{
                    "stuId":data.stuId,
                    "stuName":data.stuName,
                    "stuSex":data.stuSex,
                    "className":data.className,
                    "selfId":data.selfId,
                    "stuPwd":data.stuPwd,
                    "stuPhone":data.stuPhone,
                    "stuItb":data.stuItb,
                });
            }else if (e.event=="reSetPwd"){
                data.stuPwd="888888";
                layer.confirm('您确认要重置密码吗？',function () {
                $.ajax({
                    type:"post",
                    url:"../StudentServlet?method=update",
                    //data:"stuId="+data.stuId+"&stuName="+data.stuName+"&stuSex="+data.stuSex+"&classId="+data.classId+"&selfId="+data.selfId+"&stuPwd="+888888+"&stuPhone="+data.stuPhone+"&stuItb="+data.stuItb,//把数据发送到对应的路径
                    data:"json="+JSON.stringify(data),
                    dataType:"text",
                    success:function(data){
                        if (data=="ok"){
                            layer.msg("重置密码成功！")
                            table.reload('demo');
                        }else{
                            layer.msg("重置密码失败！")
                        }
                    }
                });
                layer.msg("密码重置成功!");
                table.reload('demo');
                });
            }

        });
        //判断点击的是搜索
        form.on("submit(search)",function(data){
            //获取数据
            var dataTable=data.field;
            //判断是否输入全部为空
            if ( dataTable.stuName!=""||dataTable.classId!="" || dataTable.stuItb!=""){
                //重载表格，刷新时发送数据
                table.reload("demo",{
                    page:{//刷新后从第几页开始显示
                        curr: 1
                    },
                    where:{
                        stuName:dataTable.stuName,
                        classId:dataTable.classId,
                        stuItb:dataTable.stuItb
                    }
                });
            }else{
                layer.msg("请输入内容");

            }
        });


        //判断点击的是添加还是批量删除
        table.on("toolbar(test)",function (data) {
            //让主键可以输入
            $("#stopText").removeAttr("readonly");
            //判断点击的是添加
            if (data.event=="add"){
                //将确认按钮改为增加
                $("#okk").text("增加");
                //调出窗口
                closeDiv=layer.open({
                    type:1,
                    title:"增加内容",
                    offset: 'auto',
                    area:["500px","600px"],
                    content:$("#MaxDiv").html()
                });
                //更新下拉框状态
                layui.use('form', function(){
                    var form = layui.form;
                    form.render(); //更新  所在容器内的全部 select 状态
                });


            }else if (data.event=="allDelete"){//点击的是批量删除
                //拿到复选框选中行数据
                var data1=table.checkStatus(data.config.id).data;
                if (data1.length>0){
                    layer.confirm('确定要删除吗?', {icon: 3, title:'提示'}, function(index){
                        var stuIdStr="";
                        $.each(data1,function(index,item){
                            stuIdStr+=item.stuId+",";
                        });
                        stuIdStr=stuIdStr.substring(0,stuIdStr.length-1);
                        //通过ajax发送数据
                        $.ajax({
                            type:"post",
                            url:"../StudentServlet?method=batchDel",
                            data:"stuIdStr="+stuIdStr,
                            dataType:"text",
                            success:function(data){
                                if (data=="ok"){
                                    layer.msg("删除成功")
                                    table.reload('demo');
                                }else{
                                    layer.msg("删除失败")
                                }
                            }
                        });
                        layer.close(index);
                    });
                }else{
                    layer.msg("请选择数据再进行删除！");
                }
            }
        });


        //判断点击的是修改还是增加
        form.on("submit(okkFilter)",function(data){
            //拿到jQuery元素
            var elem=$("#okk").text();
            //var elem=$(data.elem);//因为拿到的是dom对象所以要转换成jqeury对象才可以调用text()
            //alert(elem.text());
            //判断点击的按钮是修改还是增加
            if (elem=="修改"){
                //将数据发送到服务器端
                $.ajax({
                    type:"POST",
                    url:"../StudentServlet?method=update",
                    data:"json="+JSON.stringify(data.field),
                    dataType:"text",
                    success:function(data){
                        //判断修改是否成功
                        if (data=="ok"){
                            layer.msg("修改成功");
                            table.reload('demo');
                        }else{
                            layer.msg("修改失败");
                        }
                    }
                });
                //不管添加成功还是失败，都需要清空对话框，防止为下次添加时造成影响
                $("#mainForm")[0].reset();
                //关闭对话框
                layer.close(closeDiv);
                return false;//不进行跳转，也就是不再表格显示时再次请求XXX.json
            }else if (elem=="增加"){//判断点击的为增加
                //将数据发送到服务器端
                $.ajax({
                    type:"POST",
                    url:"../StudentServlet?method=add&className="+data.field.className,
                    data:{"json":JSON.stringify(data.field)},
                    dataType:"text",
                    success:function(data){
                        if (data=="ok"){
                            layer.msg("添加成功");
                            table.reload('demo');
                        }else{
                            layer.msg("添加失败");
                        }
                    }
                });
                //清空表单框
                $("#mainForm")[0].reset();
                //关闭窗口
                layer.close(closeDiv);
                //不跳转
                return false;
            }
        });

    });
</script>
</body>
</html>
